草庐IT

ThinkPHP 6 数据条件查询总结

全部标签

ruby-on-rails - 有条件地链接范围的最佳方法

我正在尝试扩展服务器端数据表的功能。我将一些额外的过滤器传递到我的Controller/数据表,我用它来过滤结果。目前在我的模型中,我在应用我的范围之前测试参数是否存在,但我不相信这是最好的方法,因为当我的过滤器列表增长时,我会有很多if/else场景。我怎样才能以“rails方式”做到这一点?ifparams[:store_id].present?&¶ms[:status].present?Order.store(params[:store_id]).status(params[:status])elsifparams[:store_id].present?&&!params

ruby-on-rails - 从表中删除与数组中的数据匹配的记录?

我有一个包含2个字段的表。单词和时间戳。然后我有这个包含一些单词的数组。如何删除表中与数组中的单词匹配的所有记录?假设模型名为“Word”。关于如何实现这一点有什么想法吗?可能遍历数组并运行一些销毁查询。有人可以指导我吗?谢谢 最佳答案 这样做:Word.delete_all(:words=>words_array)这将在一个SQL语句中删除与给定数组中的单词匹配的行。例如:words=["pop","popalternative","r&b"]Word.delete_all(:words=>words)

ruby-on-rails - 在仅数据迁移期间绕过验证以修复验证错误

在rails中,我有迁移来改变生产数据以适应新的验证规则,有几处错误所以我有2个不同的迁移(它们可能是一个但仍然是分开运行的两个方面)一个失败,因为另一个验证不是遇到了,反之亦然验证在模型中是新的,例如validates_uniqueness_of:job_id,:scope=>[:day,:time,:user_id,:overtime,:comments],:message=>"DuplicateEntry,Pleasecheckyourdata"validates_uniqueness_of:job_id,:scope=>[:day,:user_id,:comments],:me

ruby-on-rails - Rails 控制台中有没有办法打印数据库目录?

我正在寻找一种干净简单的方法来在Rails控制台中打印我的5行2列数据库的内容。有什么想法吗?我用Google搜索了一下,但没找到多少。 最佳答案 我认为你应该首先使用hirbgem,它提供了一种非常愉快的方式来打印您的表格列。安装hirbgem:geminstallhirb将此gem添加到您项目的Gemfile:gem'hirb'转到项目的根文件夹并运行Rails控制台:railsc在控制台中启用hirb:require'hirb'Hirb.enable如果你想限制显示的行数,你可以这样做:Model.limit(n)例如:Use

ruby-on-rails - 通过 rails 中的多个条件查找

我想在Rails中搜索具有多个条件的表。我正在使用Activerecord和rails版本3.1.0。我有Movies对象,并希望在rails中实现以下等价物:Select*fromMovieswhererating='R'ORrating='PG'我尝试了以下方法,但它不起作用@filtered=Movies.find(:all,:conditions=>{:rating=>'R',:rating=>'PG'})能否请您帮助编写与上述SQL查询等效的内容。 最佳答案 一种方法是建立一个“IN”条件:@filtered=Movie.

ruby-on-rails - 如何获取 ActiveRecord 在 Ruby on Rails 中执行的最后一个 SQL 查询?

我正在寻找类似CodeIgniter的东西:$this->db->last_query();(http://codeigniter.com/user_guide/database/helpers.html) 最佳答案 据我所知,访问查询列表并不容易。尽管如此,您还是可以轻松访问它们,创建一个super简单的记录器。如果您打开ActiveRecord::ConnectionAdapters::AbstractAdapter类,您将看到一个名为log的方法。在每个查询上调用此方法以记录语句。默认情况下,它使用Rails记录器记录所有语句

ruby-on-rails - 我们是否将 Rails ActiveRecord 用作混合结构,即数据结构 + 对象?

我使用Rails已经4年多了,所以很明显我喜欢Rails并且喜欢按照Rails方式做事,但有时我会在不知不觉中陷入阴暗面。我最近学习了UncleBob的CleanCode。我在看第6章,有点困惑我们作为Rails开发人员是否违反了OO设计的最基本规则,即Demeter法则或封装?得墨忒耳法则指出,一个对象不应该知道另一个对象的内部结构,也不应该调用方法返回的对象的方法,因为当你这样做时,它表明一个对象对另一个对象了解太多。但我们经常从一个模型中调用另一个对象的方法。例如,当我们有像“订单属于用户”这样的关系时。然后很多时候我们最终会执行order.user.name或者为了防止它看起来

ruby-on-rails - 如何在 Rails 3 事件记录中链接查询

我需要根据参数数据添加条件。@users=User.where('id',params[:id])unlessparams[:id].nil?@users=User.where('email',params[:email])unlessparams[:email].nil?@users=User.limit(10)但由于某些原因它不起作用。谢谢 最佳答案 您的每个语句都替换了@users变量,并且当ActiveRecord延迟计算每个语句时,永远不会调用前两个。如果您想维护三个独立的查询并以这种方式构建事物,您可以这样做:@user

css - 从 ruby​​ Controller 有条件地设置 CSS 样式

我正在尝试动态更改(如果它被点击)一个普通的表头(这是一个链接)到另一个定义的CSS类“th.hilite”。此链接只是对该列进行排序,每次用户对列表进行排序时,标题都应该突出显示。应该更改相关类的View,如下所示:%table#mytable%thead%tr%th=link_to'Title',mytable_path(:sort=>'title'),:id=>'title_header'我的问题很简单:如果单击标题,我如何以及在何处将类动态设置为%th.hilite? 最佳答案 您可以直接从View绑定(bind)它:%th

ruby-on-rails - 将用户生成的文本安全地存储在数据库中 (Ruby/Rails)

我正在尝试找到一种方法将用户生成的文本安全地存储在数据库中(这样只有用户才能访问他/她存储的文本)。我可以让Rails使用用户密码作为key来加密和解密用户的文本条目,但是如果用户忘记了他们的密码,就没有办法解密他们以前的内容/文本(因为Rails应用程序使用BCrypt来仅存储密码的哈希值)。有人知道怎么做吗?看起来Dropbox做了类似的事情:“存储在Dropbox服务器上的所有文件都经过加密(AES-256),没有您的帐户密码就无法访问。”(http://www.dropbox.com/help/27)然而,它们允许您重置密码,我假设它们不会在任何地方存储您的纯文本密码。我错过了